home *** CD-ROM | disk | FTP | other *** search
/ Cream of the Crop 26 / Cream of the Crop 26.iso / os2 / octa209s.zip / octave-2.09 / liboctave / dbleDET.cc < prev    next >
C/C++ Source or Header  |  1996-03-03  |  1KB  |  71 lines

  1. /*
  2.  
  3. Copyright (C) 1996 John W. Eaton
  4.  
  5. This file is part of Octave.
  6.  
  7. Octave is free software; you can redistribute it and/or modify it
  8. under the terms of the GNU General Public License as published by the
  9. Free Software Foundation; either version 2, or (at your option) any
  10. later version.
  11.  
  12. Octave is distributed in the hope that it will be useful, but WITHOUT
  13. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  14. FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  15. for more details.
  16.  
  17. You should have received a copy of the GNU General Public License
  18. along with Octave; see the file COPYING.  If not, write to the Free
  19. Software Foundation, 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  20.  
  21. */
  22.  
  23. #if defined (__GNUG__)
  24. #pragma implementation
  25. #endif
  26.  
  27. #ifdef HAVE_CONFIG_H
  28. #include <config.h>
  29. #endif
  30.  
  31. #include <cfloat>
  32. #include <cmath>
  33.  
  34. #include "dbleDET.h"
  35.  
  36. int
  37. DET::value_will_overflow (void) const
  38. {
  39.   return det[2] + 1 > log10 (DBL_MAX) ? 1 : 0;
  40. }
  41.  
  42. int
  43. DET::value_will_underflow (void) const
  44. {
  45.   return det[2] - 1 < log10 (DBL_MIN) ? 1 : 0;
  46. }
  47.  
  48. double
  49. DET::coefficient (void) const
  50. {
  51.   return det[0];
  52. }
  53.  
  54. int
  55. DET::exponent (void) const
  56. {
  57.   return (int) det[1];
  58. }
  59.  
  60. double
  61. DET::value (void) const
  62. {
  63.   return det[0] * pow (10.0, det[1]);
  64. }
  65.  
  66. /*
  67. ;;; Local Variables: ***
  68. ;;; mode: C++ ***
  69. ;;; End: ***
  70. */
  71.